home *** CD-ROM | disk | FTP | other *** search
/ Amiga Format CD 24 / Amiga Format AFCD24 (Feb 1998, Issue 108).iso / -in_the_mag- / emulation / amiga / uae-0.7.0b2 / src / build68k.c < prev    next >
C/C++ Source or Header  |  1998-01-20  |  6KB  |  244 lines

  1. /*
  2.  * UAE - The Un*x Amiga Emulator
  3.  *
  4.  * Read 68000 CPU specs from file "table68k" and build table68k.c
  5.  *
  6.  * Copyright 1995,1996 Bernd Schmidt
  7.  */
  8.  
  9. #include "sysconfig.h"
  10. #include "sysdeps.h"
  11.  
  12. #include <assert.h>
  13. #include <ctype.h>
  14.  
  15. #include "config.h"
  16. #include "options.h"
  17. #include "readcpu.h"
  18.  
  19. static FILE *tablef;
  20. static int nextch = 0;
  21.  
  22. static void getnextch(void)
  23. {
  24.     do {
  25.     nextch = fgetc(tablef);
  26.     if (nextch == '%') {
  27.         do {
  28.         nextch = fgetc(tablef);
  29.         } while (nextch != EOF && nextch != '\n');
  30.     }
  31.     } while (nextch != EOF && isspace(nextch));
  32. }
  33.  
  34. static int nextchtohex(void)
  35. {
  36.     switch (isupper (nextch) ? tolower (nextch) : nextch) {
  37.      case '0': return 0;
  38.      case '1': return 1;
  39.      case '2': return 2;
  40.      case '3': return 3;
  41.      case '4': return 4;
  42.      case '5': return 5;
  43.      case '6': return 6;
  44.      case '7': return 7;
  45.      case '8': return 8;
  46.      case '9': return 9;
  47.      case 'a': return 10;
  48.      case 'b': return 11;
  49.      case 'c': return 12;
  50.      case 'd': return 13;
  51.      case 'e': return 14;
  52.      case 'f': return 15;
  53.      default: abort();
  54.     }
  55. }
  56.  
  57. int main(int argc, char **argv)
  58. {
  59.     int no_insns = 0;
  60.  
  61.     printf ("#include \"sysconfig.h\"\n");
  62.     printf ("#include \"sysdeps.h\"\n");
  63.     printf ("#include \"config.h\"\n");
  64.     printf ("#include \"options.h\"\n");
  65.     printf ("#include \"readcpu.h\"\n");
  66.     printf ("struct instr_def defs68k[] = {\n");
  67.     tablef = fopen("table68k","r");
  68.     if (tablef == NULL) {
  69.     fprintf(stderr, "table68k not found\n");
  70.     exit(1);
  71.     }
  72.     getnextch();
  73.     while (nextch != EOF) {
  74.     int cpulevel, plevel, sduse;
  75.     int i;
  76.  
  77.     char patbits[16];
  78.     char opcstr[256];
  79.     int bitpos[16];
  80.     int flagset[5], flaguse[5];
  81.  
  82.     unsigned int bitmask,bitpattern;
  83.     int n_variable;
  84.  
  85.     n_variable = 0;
  86.     bitmask = bitpattern = 0;
  87.     memset (bitpos, 0, sizeof(bitpos));
  88.     for(i=0; i<16; i++) {
  89.         int currbit;
  90.         bitmask <<= 1;
  91.         bitpattern <<= 1;
  92.  
  93.         switch (nextch) {
  94.          case '0': currbit = bit0; bitmask |= 1; break;
  95.          case '1': currbit = bit1; bitmask |= 1; bitpattern |= 1; break;
  96.          case 'c': currbit = bitc; break;
  97.          case 'C': currbit = bitC; break;
  98.          case 'f': currbit = bitf; break;
  99.          case 'i': currbit = biti; break;
  100.          case 'I': currbit = bitI; break;
  101.          case 'j': currbit = bitj; break;
  102.          case 'J': currbit = bitJ; break;
  103.          case 'k': currbit = bitk; break;
  104.          case 'K': currbit = bitK; break;
  105.          case 's': currbit = bits; break;
  106.          case 'S': currbit = bitS; break;
  107.          case 'd': currbit = bitd; break;
  108.          case 'D': currbit = bitD; break;
  109.          case 'r': currbit = bitr; break;
  110.          case 'R': currbit = bitR; break;
  111.          case 'z': currbit = bitz; break;
  112.          default: abort();
  113.         }
  114.         if (!(bitmask & 1)) {
  115.         bitpos[n_variable] = currbit;
  116.         n_variable++;
  117.         }
  118.  
  119.         if (nextch == '0' || nextch == '1')
  120.         bitmask |= 1;
  121.         if (nextch == '1')
  122.         bitpattern |= 1;
  123.         patbits[i] = nextch;
  124.         getnextch();
  125.     }
  126.  
  127.     while (isspace(nextch) || nextch == ':') /* Get CPU and privilege level */
  128.         getnextch();
  129.  
  130.     switch (nextch) {
  131.      case '0': cpulevel = 0; break;
  132.      case '1': cpulevel = 1; break;
  133.      case '2': cpulevel = 2; break;
  134.      case '3': cpulevel = 3; break;
  135.      case '4': cpulevel = 4; break;
  136.      default: abort();
  137.     }
  138.     getnextch();
  139.  
  140.     switch (nextch) {
  141.      case '0': plevel = 0; break;
  142.      case '1': plevel = 1; break;
  143.      case '2': plevel = 2; break;
  144.      case '3': plevel = 3; break;
  145.      default: abort();
  146.     }
  147.     getnextch();
  148.  
  149.     while (isspace(nextch))                   /* Get flag set information */
  150.         getnextch();
  151.  
  152.     if (nextch != ':')
  153.         abort();
  154.  
  155.     for(i = 0; i < 5; i++) {
  156.         getnextch();
  157.         switch(nextch){
  158.          case '-': flagset[i] = fa_unset; break;
  159.          case '/': flagset[i] = fa_isjmp; break;
  160.          case '0': flagset[i] = fa_zero; break;
  161.          case '1': flagset[i] = fa_one; break;
  162.          case 'x': flagset[i] = fa_dontcare; break;
  163.          case '?': flagset[i] = fa_unknown; break;
  164.          default: flagset[i] = fa_set; break;
  165.         }
  166.     }
  167.  
  168.     getnextch();
  169.     while (isspace(nextch))
  170.         getnextch();
  171.  
  172.     if (nextch != ':')                        /* Get flag used information */
  173.         abort();
  174.  
  175.     for(i = 0; i < 5; i++) {
  176.         getnextch();
  177.         switch(nextch){
  178.          case '-': flaguse[i] = fu_unused; break;
  179.          case '/': flaguse[i] = fu_isjmp; break;
  180.          case '+': flaguse[i] = fu_maybecc; break;
  181.          case '?': flaguse[i] = fu_unknown; break;
  182.          default: flaguse[i] = fu_used; break;
  183.         }
  184.     }
  185.  
  186.     getnextch();
  187.     while (isspace(nextch))
  188.         getnextch();
  189.  
  190.     if (nextch != ':')                        /* Get source/dest usage information */
  191.         abort();
  192.  
  193.     getnextch();
  194.     sduse = nextchtohex() << 4;
  195.     getnextch();
  196.     sduse |= nextchtohex();
  197.  
  198.     getnextch();
  199.     while (isspace(nextch))
  200.         getnextch();
  201.  
  202.     if (nextch != ':')
  203.         abort();
  204.  
  205.     fgets(opcstr, 250, tablef);
  206.     getnextch();
  207.     if (cpulevel <= CPU_LEVEL) {
  208.         int j;
  209.         /* Remove superfluous spaces from the string */
  210.         char *opstrp = opcstr, *osendp;
  211.         int slen = 0;
  212.  
  213.         while (isspace(*opstrp))
  214.         opstrp++;
  215.  
  216.         osendp = opstrp;
  217.         while (*osendp) {
  218.         if (!isspace (*osendp))
  219.             slen = osendp - opstrp + 1;
  220.         osendp++;
  221.         }
  222.         opstrp[slen] = 0;
  223.  
  224.         if (no_insns > 0)
  225.         printf(",\n");
  226.         no_insns++;
  227.         printf("{ %d, %d, {", bitpattern, n_variable);
  228.         for (j = 0; j < 16; j++) {
  229.         printf("%d", bitpos[j]);
  230.         if (j < 15)
  231.             printf(",");
  232.         }
  233.         printf ("}, %d, %d, { ", bitmask, plevel);
  234.         for(i = 0; i < 5; i++) {
  235.         printf("{ %d, %d }%c ", flaguse[i], flagset[i], i == 4 ? ' ' : ',');
  236.         }
  237.         printf("}, %d, \"%s\"}", sduse, opstrp);
  238.     }
  239.     }
  240.     printf("};\nint n_defs68k = %d;\n", no_insns);
  241.     fclose(tablef);
  242.     return 0;
  243. }
  244.